$(function () {
    // 1.1 获取裁剪区域的 DOM 元素
    var $image = $('#image')
    // 1.2 配置选项
    const options = {
        // 纵横比
        aspectRatio: 1,
        // 指定预览区域
        preview: '.img-preview'
    }

    // 1.3 创建裁剪区域
    $image.cropper(options)

    // 点击上传文件
    $('#btnUpload').on('click', function () {
        $('#file').click();
    })
    $('#file').on('change', function (e) {
        // 获取用户选择的文件列表 
        var files = e.target.files
        if (files.length === 0) {
            return layui.layer.msg('请选择照片！')
        }
        // 将文件渲染到页面
        // 1. 拿到用户选择的文件  e.target.files是个伪数组
        var file = e.target.files[0]
        // 2. 将文件，转化为路径
        var imgURL = URL.createObjectURL(file)
        // 3. 重新初始化裁剪区域
        $image
            .cropper('destroy') // 销毁旧的裁剪区域
            .attr('src', imgURL) // 重新设置图片路径
            .cropper(options) // 重新初始化裁剪区域
    })
    // 点击确定按钮将文件上传
    $('#btnok').on('click', function () {
        // 拿到裁剪后的图片，输出为base64格式的图片
        var dataURL = $image
            .cropper('getCroppedCanvas', {
                // 创建一个 Canvas 画布
                width: 100,
                height: 100
            })
            .toDataURL('image/png')
        // 调用上传图片请求
        $.ajax({
            method: 'POST',
            url: '/my/update/avatar',
            data: {
                avatar: dataURL
            },
            success: function (res) {
                if (res.status !== 0) {
                    return layui.layer.msg('更新用户头像失败')
                }
                layui.layer.msg('更新用户头像成功')
                // 调用获取用户信息函数，渲染页面头像
                window.parent.getUserinfo();
            }
        })
    })
})
